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#1 


Posted 02 February 2005 - 10:48 AM 


Storing server, domains, users and groups in a Database via ODBC 
This requires at least v3.1.0 build 70. 
How-to 


1. First, you'll have to create the tables, here are the tables structures, download the sqi files : [7 


odbc_settings.Zip (4.06K) 
Number of downloads: 2344 for Mysql, Postgresql, MS SQL (provided by ADutch1), Oracle (provided by Oaxa) 


For instance, you can import these tables for Mysql with PhoMyAdmin. 


2. Once the tables are created (you should have 8 tables), you'll have to create a file named account.ini in your 
installation directory and copy this to tell the server to use ODBC : 


PnP PPP PP PP OP 
[Settings] 
Storage=ODBC 


[ODBC] 

;ConnectionString=Provider=MSDASQL.1;Persist Security Info=False; Data Source=mysql-odbc 
ConnectionString=DSN=mysql-odbc 

UserlD= 

Password= 

; Set to 0 if your sql server doesn't support foreign keys (e.g. mysql), set 

; to -1 otherwise 

ForeignKeys=0 

; This setting tells the server how to quote values in SQL queries 

; 0 = backslashes characters that need to be quoted in queries (e.g. ‘O\'reilly') 
; 1 = double quotes in queries (e.g. 'O"reilly') 

Escape lype=0 


PP PP PP PP PP PO 


For MS SQL (provided by ADutch’) : 


PP PPP PP PP —>-->—>—> 
[Settings] 
Storage=ODBC 


[ODBC] 

ConnectionString=DSN={whatever you named the SystemDSN in the ODBC control panel} 
UserlD={user account to connect to the DB in SQL} 

Password={password if the user account above} 

; Set to 0 if your sql server doesn't support foreign keys (e.g. mysql), set 

; to -1 otherwise 

ForeignKeys=-1 

; This setting tells the server how to quote values in SQL queries 

; 0 = backslashes characters that need to be quoted in queries (e.g. ‘O\'reilly') 
; 1 = double quotes in queries (e.g. 'O"reilly') 

Escape Type=1 

* —>—>——> —>-- > — > — > —> — > -- > —- > — > — > --> —> —> 
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For Oracle (provided by Oaxa) : 


oP PP PPP PP PP OP 
[Settings] 
Storage=ODBC 


[ODBC] 

;ConnectionString=Provider=MSDASQL.1;Persist Security Info=False; Data Source=mysql-odbc 
ConnectionString=DSN=ORADC_G6 

UserlD={user account to connect to the DB in SQL} 

Password={password if the user account above} 


; Set to 0 if your sql server doesn't support foreign keys (e.g. mysql), set 

; to -1 otherwise 

ForeignKeys=-1 

; This setting tells the server how to quote values in SQL queries 

; 0 = backslashes characters that need to be quoted in queries (e.g. ‘O\'reilly') 
; 1 = double quotes in queries (e.g. 'O"reilly') 

Escape Type=1 


-> —>—>—>-->—>—> —> — > -- > — > — > —>-->—> —> 


3. Then you can create a system ODBC link with the name "mysql-odbc" linking to your mySQL database or 
you can change the ConnectionString with the parameters to connect to your SQL server. 


4. Start the server and in "FTP Server/Logs & Reports/Main log" you should see the line "Accounts storage : 
‘ODBC v0. 1'." instead of "Accounts storage : 'Inifilles v2.8'.". 


If the ODBC source is not available the server will report a startup error in <installation path>\g6ftpserver-error.log 
and will use default inifile storage. 


Uninstall 
Stop the senice and rename (or delete) the inifile, then restart the service. 
Problems 


Deleting users does not work : 
http://www. g6ftpserver.com/forum/index. pho?showtopic=1535 


Duplicate entry error logged in G6F TPServer-error.log : 
http://www. g6ftpserver.com/forum/index. php...ost&p=10014 


Gene6, SARL 
Do not use MMto ask for support, use the forumor support email. 
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Posted 06 March 2005 - 09:43 AM 


There was a similar error with a mysqlodbc version : 
Gene6 http://www.g6ftpserver.com/forum/index. php... findpost&p=6628 
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Posted 19 March 2005 - 05:02 AM 


| also would like to know how to set this up for a SQI database. | also wonder what information all can be stored 
in the database and how often does Geneé read the database. 


Posted 19 March 2005 - 11:13 AM 


SQL server can be used but there is currently no database structure available. 
| have no sql server to test at the moment, so | suggest you base your structure on mysql one. 
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Posted 19 March 2005 - 03:12 PM 


M.Roger, 


Thanks for the reply. | was just wondering what columns are all needed/possible in the tables? | would like to 
control pretty much all user settings from the DB in SQL if possible. 


Thanks, 


Posted 20 March 2005 - 12:08 PM 


You can see which are needed by looking at the structures : http://www.g6ftpserver.com/files/odbc-sql-tables.sql 


Gene6, SARL 
Do not use PMto ask for support, use the forumor support email. 
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Member Ok, I hate bugging about this but refering me to the link is not really helping (i found the link already by myself). 
ae 
pies oe | am looking into buying this product (a lot of them) and | don't seem to get a decend answer here... 
osts: 


Joined: 19-NMerch 05 ; ; 
Are you telling me that the FTP server and DB do NOT synchronize? Meaning, | can't see in the FTP server 


program the accounts | create in the DB? 


Also, it seems that the FTP program uses one (or more) MANUALLY created accounts and compares them to 
the users in the DB to provide rights, account settings etc.??? Seems a little weird.. why not read straight out of 
the DB and use tables in the DB to populate the fields in the FTP program? 


| need to be able to go to the server and look at the FTP accounts (coming from the DB) and have one central 
DB feeding multiple FTP servers... (like Sern+U and WSFTP do). 


Thanks, 


V 


Matthieu #10 


Posted 20 March 2005 - 07:36 PM 


QUOTE 
Are you telling me that the FTP server and DB do NOT synchronize? Meaning, | can't see in the FTP server 


Geneb 


Addicted Member program the accounts | create in the DB? 
[es | STAFF | 
Group: Staff 
Posts: 1964 No, this is transparent for the server, whether you store in ini or DB it will show you all accounts and settings (it 
ait 7 October 03 will read/save them from/to ini when using ini, and from/to DB when using DB). Using the administration client 
naer: e : : : a8 
a E on and DB, you will see everything as when you are using ini files. 
Interests: Science-fiction, World 
news QUOTE 
Also, it seems that the FTP program uses one (or more) MANUALLY created accounts and compares them to 
the users in the DB to provide rights, account settings etc.??? Seems a little weird.. why not read straight out of 
the DB and use tables in the DB to populate the fields in the FTP program? 
It looks that you are talking about authentication against DB, not complete storage in a DB which is different 
from this topic. 
Gene6, SARL 
Do not use PMMto ask for support, use the forumor support email. 
Special offer : 10% discount with coupon code : DISCOUNT 
0 
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Member Matthieu, 
ae 
elas eo | think we are having a little misunderstanding here about what we are exactly talking about... 
osts: 


Joined: 19-March 05 


What | am looking for is a method to store/enter all user information/settings in a DB and having the FTP 
program use this information to populate it's fields. When | open up the administration program of the FTP server, 
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| want to see the information in the FTP server (under the Users) that | entered in the DB. 


If this program is capable of doing this then it is the fit | am looking for and | would like to get more detailed 
information regarding this. | don't see that anywhere in your documentation though. | DO find the information 
where you can create a account in the FTP program and use that to authenthicate against from a DB but | can't 
seem to find anywhere how to create a table in the DB with all the fields you see in the user settings. | also don't 
see anywhere where it would show these accounts (created in the DB) back into the FTP program. 


So, all the fields that you see in the FTP program, | would like to know what columns | would need to create in a 
DB so that the FTP program would use them. If you look at (for example) Serv-U, they have a section in their 
program where you can reference all the user and group settings to a specific table/column in a DB. The DB and 
the FTP program synchronize both ways every 30 sec to synchronize the users. 


Thanks, 


Victor 


#12 


Posted 21 March 2005 - 05:03 PM 


QUOTE 

What | am looking for is a method to store/enter all user information/settings in a DB and having the FTP 
program use this information to populate it's fields. When | open up the administration program of the FTP server, 
| want to see the information in the FTP server (under the Users) that | entered in the DB. 


Yes, its does that, it is the main interest and what I'm talking about since the beginning D) 


If you use odbc storage then you can view settings you added from another application directly to the DB. 


QUOTE 
| can't seem to find anywhere how to create a table in the DB wih all the fields you see in the user settings. | 
also don't see anywhere where it would show these accounts (created in the DB) back into the FTP program. 


You don't need to create columns, you need the settings name (which are the same as when using ini), you 
have 2 general fields in the tables : ConfigName, ConfigValue which store the information. 


The ConfigName are taken from Ill Properties : http://www.g6ftpserver.com/manuals/devguide_en/ 


Since there can be new options additions, using this method allows us to not have to create or update all the 
column names (there is a lot of settings ...). 


For instance, the property "Enabled" for a user would be seen as : 


ConfigName=Enabled 
ConfigValue=1/0 


In the table User_settings : 


UserlD | ConfigName | ConfigValue 
0 | Enabled | 1 


If you have installed the evaluation version, then you can test this and see how the server uses them directly but 
as | said : this is transparent to you when using the administration client; instead of reading/sauing to ini file it 
will read/save information from the DB even when added from another applications which writes to the database. 


Only logged users that you are editing the settings externally (not via the server admin) will have their settings 
cached (up to 2 minutes), new created accounts (admin or externally added to the DB) will be immediately 
available. 


| hope this answers to your questions £} 


Gene6, SARL 
Do not use MMto ask for support, use the forumor support email. 
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Member OK, a light just came on in my head =) 
ae 
Group: Menbe 
abe - 44 > | totally didn't get the .ini part where you tell the server to use ODBC! My fault! 
Joined: 19-March 05 | was looking in the program itself under the authenthication part... 


| will try this as soon as possible and let you know if | can find anything else | can be a total idiot about & 
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Member Almost got it working... | will upload the MS SQL script to create the tables and the account INI file for other 
am users. Also a little user step by step instructions... D) 
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Posted 21 March 2005 - 09:58 PM 


Member Matthieu, 
T 
Group: Menbers 
Posts: 14 
Joined: 19-March 05 


One more problem (yeah, yeah | know)... 


It seems that the Servers are not being assigned an ID. The problem with this is that | have one database with all 
the accounts, feeding multiple FTP servers... 


Meaning... | can't create multiple tables (databases) for all the seperate FTP servers. Is there a chance this is 
added in the new version? 


V 


ADutch1 #16 


Posted 21 March 2005 - 10:25 PM 


Member Ok, attached is the account.ini file. This file needs to go into the install directory. 
a Make sure you edit the file and replace the {values} with the proper information... 
Group: Menbers 
Posts: 14 Attached File(s) 


Joined: 19-Merch 05 o. 
account. ini (546bytes) 


Number of downloads: 764 


ADutch1 #17 


Posed 21 March 2005 - 10:27 PM 


Member Then create a Database in SQL (if you haven't done already) and add the SQL user to it that you mentioned in 
mu the SystemDSN. Make sure you give him DBO rights to the DB. Run the attached SQL script against the DB to 
Group: Menbers create the tables. 
Posts: 14 
Joined: 19-March 05 Attached File(s) 


gêmssql.sq! (13.69K) 


Number of downloads 1179 
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#18 
Posted 21 March 2005 - 10:29 PM 
Stop and Start the FTP server and that should do the trick. Add a user or change any settings, check the log 
and/or watch the tables for new entries... 
Let me know if this works and if you run into any problems. 
0 
#19 


Posted 22 March 2005 - 02:51 PM 


Great O | guess this will help some other users here. 


QUOTE 
It seems that the Servers are not being assigned an ID. The problem with this is that | have one database with all 
the accounts, feeding multiple FTP servers... 


I'm not sure this can be done. Only main server config will be affected (=> they will all have same main setup so 
take care of ip binding), | don't think you will host same domain name on different server. 


Gene6, SARL 
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Posted 22 March 2005 - 03:47 PM 


You might have to change some code in the FIP program but it looks like you just need to add a table in the DB 
called Servers with the fields ID and Servername. Link the ID to the other tables including all the user and groups 
tables (since you will have different users and groups for different servers). Maybe something in a new version? 
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